---
title: 커스텀 ConnectButton
description: 커스텀 ConnectButton 만들기
---

# 커스텀 ConnectButton

## 커스텀 ConnectButton 만들기

사용자는 `ConnectButton.Custom`을 활용하여 자신의 커스텀 연결 버튼을 만들 수 있습니다. 이 컴포넌트는 기본 제공 버튼을 다시 구현하는 데 필요한 모든 내용을 포함한 함수를 렌더링합니다.

기본 제공 버튼의 최소한의 재구현은 다음과 같은 모습일 것입니다:

```tsx
import { ConnectButton } from '@rainbow-me/rainbowkit';

export const YourApp = () => {
  return (
    <ConnectButton.Custom>
      {({
        account,
        chain,
        openAccountModal,
        openChainModal,
        openConnectModal,
        authenticationStatus,
        mounted,
      }) => {
        // Note: If your app doesn't use authentication, you
        // can remove all 'authenticationStatus' checks
        const ready = mounted && authenticationStatus !== 'loading';
        const connected =
          ready &&
          account &&
          chain &&
          (!authenticationStatus ||
            authenticationStatus === 'authenticated');

        return (
          <div
            {...(!ready && {
              'aria-hidden': true,
              'style': {
                opacity: 0,
                pointerEvents: 'none',
                userSelect: 'none',
              },
            })}
          >
            {(() => {
              if (!connected) {
                return (
                  <button onClick={openConnectModal} type="button">
                    Connect Wallet
                  </button>
                );
              }

              if (chain.unsupported) {
                return (
                  <button onClick={openChainModal} type="button">
                    Wrong network
                  </button>
                );
              }

              return (
                <div style={{ display: 'flex', gap: 12 }}>
                  <button
                    onClick={openChainModal}
                    style={{ display: 'flex', alignItems: 'center' }}
                    type="button"
                  >
                    {chain.hasIcon && (
                      <div
                        style={{
                          background: chain.iconBackground,
                          width: 12,
                          height: 12,
                          borderRadius: 999,
                          overflow: 'hidden',
                          marginRight: 4,
                        }}
                      >
                        {chain.iconUrl && (
                          <img
                            alt={chain.name ?? 'Chain icon'}
                            src={chain.iconUrl}
                            style={{ width: 12, height: 12 }}
                          />
                        )}
                      </div>
                    )}
                    {chain.name}
                  </button>

                  <button onClick={openAccountModal} type="button">
                    {account.displayName}
                    {account.displayBalance
                      ? ` (${account.displayBalance})`
                      : ''}
                  </button>
                </div>
              );
            })()}
          </div>
        );
      }}
    </ConnectButton.Custom>
  );
};
```

다음 속성들은 render 함수에 전달됩니다.

### 계정 속성

<PropsTable
  data={[
    {
      name: 'account',
      required: false,
      type: 'object | undefined',
      description:
        '현재 계정에 대한 세부 정보가 포함된 객체, 이하 설명',
    },
    {
      name: 'account.address',
      required: false,
      type: 'string',
      description: (
        <>
          전체 계정 주소, 예:
          "0x7a3d05c70581bD345fe117c06e45f9669205384f"
        </>
      ),
    },
    {
      name: 'account.balanceDecimals',
      required: false,
      type: 'string | undefined	',
      description: '소수로 표기된 계정 잔액',
    },
    {
      name: 'account.balanceFormatted',
      required: false,
      type: 'string | undefined	',
      description: (
        <>
          문자열로 형식화된 계정 잔액, 예: {' '}
          <code>1.234567890123456789</code>
        </>
      ),
    },
    {
      name: 'account.balanceSymbol',
      required: false,
      type: 'string | undefined	',
      description: (
        <>
          잔액의 화폐 기호, 예: <code>ETH</code>
        </>
      ),
    },
    {
      name: 'account.displayBalance',
      required: false,
      type: 'string | undefined	',
      description: (
        <>
          3자리의 유효 숫자로 형식화된 잔액과 기호, 예: <code>1.23 ETH</code>
        </>
      ),
    },
    {
      name: 'account.displayName',
      required: false,
      type: 'string',
      description: (
        <>
          ENS 이름 또는 주소의 축약형, 예: {' '}
          <code>"rainbowwallet.eth"</code> 또는 <code>"0x7a…384f"</code>
        </>
      ),
    },
    {
      name: 'account.ensAvatar',
      required: false,
      type: 'string	| undefined',
      description: 'ENS 아바타 URI',
    },
    {
      name: 'account.ensName',
      required: false,
      type: 'string	| undefined',
      description: (
        <>
          ENS 이름, 예: <code>rainbowwallet.eth</code>
        </>
      ),
    },
    {
      name: 'account.hasPendingTransactions',
      required: false,
      type: 'boolean',
      description:
        '현재 체인에 대한 미결 거래가 있는지 표시하는 불리언',
    },
  ]}
/>

### 체인 속성

<PropsTable
  data={[
    {
      name: 'chain',
      required: false,
      type: 'object | undefined',
      description:
        '현재 체인에 대한 세부 정보가 포함된 객체, 이하 설명',
    },
    {
      name: 'chain.hasIcon',
      required: false,
      type: 'boolean',
      description: '체인에 지정된 아이콘이 있는지 여부',
    },
    {
      name: 'chain.iconUrl',
      required: false,
      type: 'string | undefined',
      description:
        '체인 아이콘 URL (Base64 데이터 URL을 다운로드하는 동안 정의되지 않을 수 있음)',
    },
    {
      name: 'chain.iconBackground',
      required: false,
      type: 'string | undefined',
      description:
        '이미지가 로딩되는 동안 표시될 체인 아이콘 배경',
    },
    {
      name: 'chain.id',
      required: false,
      type: 'number',
      description: (
        <>
          체인 ID, 예: <code>1</code>
        </>
      ),
    },
    {
      name: 'chain.name',
      required: false,
      type: 'string | undefined',
      description: (
        <>
          체인 이름, 예: <code>"Ethereum"</code>
        </>
      ),
    },
    {
      name: 'chain.unsupported',
      required: false,
      type: 'boolean | undefined',
      description:
        '현재 체인이 지원되지 않음을 나타내는 불리언',
    },
  ]}
/>

### 모달 상태 속성

<PropsTable
  data={[
    {
      name: 'openAccountModal',
      required: false,
      type: '() => void',
      description: '계정 모달을 여는 함수',
    },
    {
      name: 'openChainModal',
      required: false,
      type: '() => void',
      description: '체인 모달을 여는 함수',
    },
    {
      name: 'openConnectModal',
      required: false,
      type: '() => void',
      description: '연결 모달을 여는 함수',
    },
    {
      name: 'accountModalOpen',
      required: false,
      type: 'boolean',
      description:
        '계정 모달이 열려 있는지 나타내는 불리언',
    },
    {
      name: 'chainModalOpen',
      required: false,
      type: 'boolean',
      description: '체인 모달이 열려 있는지 나타내는 불리언',
    },
    {
      name: 'connectModalOpen',
      required: false,
      type: 'boolean',
      description:
        '연결 모달이 열려 있는지 나타내는 불리언',
    },
  ]}
/>

### 일반 상태 속성

<PropsTable
  data={[
    {
      name: 'mounted',
      required: false,
      type: 'boolean',
      description:
        '컴포넌트가 마운트 되었는지 여부를 나타내는 불리언',
    },
    {
      name: 'authenticationStatus',
      required: false,
      type: '"loading" | "unauthenticated" | "authenticated" | undefined',
      description:
        '인증 상태, 인증이 설정되지 않은 경우 undefined',
    },
  ]}
/>
